package com.example.suanfa;

public class InsertionSort {
    public static void main(String[] args) {
        int[] arr = {9, 5, 1, 3, 4, 7, 8, 2, 6};
        sort(arr);
        print(arr);
    }

    static void sort(int[] arr) {
        //插入排序
        for (int i = 1; i < arr.length; i++) {
//            for (int j = i; j >0&&arr[j]<arr[j-1];j--){
//                swap(arr,j-1,j);
//            }
            //记录要比较的数据temp
            int temp = arr[i];
            //记录最后一个不大于temp的数据
            int max = -1;
            //进行判断temp与前面的一位数字进行判断
            for (int j = i - 1; j >= 0; j--) {
                if (temp <= arr[j]) {
                    arr[j + 1] = arr[j];
                    max = j;
                }
            }
            if (max != -1) {
                arr[max] = temp;
            }

        }
//        print(arr);
    }

    static void swap(int[] arr, int i, int j) {
        int temp = arr[i];
        arr[i] = arr[j];
        arr[j] = temp;
        //System.out.println(arr[i]+"  "+arr[j]);
    }

    static void print(int[] arr) {
        for (int i = 0; i < arr.length; i++) {
            System.out.print(arr[i] + " ");
        }
    }
}
